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HARDWARE OVERVIEW 


The Lisa hardware can be divided into four functional pieces: the 
CPU and memory management unit, the I/O circuitry, the memory arrays, 
and the expansion slots. The main microprocessor is a Motorola 
MC68000. Le communicates with the rest of the Lisa world over two 
buses: the system bus, and the memory bus. The I/O edreuitry 
includes the built-in parallel interface, two serial interfaces, 
floppy disk controller, clock-calendar, speaker, and keyboard 
interface. 
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THE PROCESSOR 


The Motorola MC68000 Microprocessor User’s Manual fully describes the 
operation of the processor, including its instruction set and timing. 
The Lisa 68000 has a5 megahertz clock. The memory cycle time is 800 
nanoseconds; therefore instructions that use a multiple of four clock 
cycles can execute without a wait state. 
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VIDEO DISPLAY 


The bit mapped display has 360 dots vertically and 720 dots horizontally. 
It is refreshed from system RAM. Since the video circuit cannot wait 
for a long bus cycle to complete, the Memory Bus provides a direct 

path from system RAM to the video refresh circuit. The CPU board 
synchronizes CPU access to system RAM with that of the video circuit. 


MEMORY 


The Lisa memory management unit addresses 16 megabytes of memory. 
Hardware on the CPU board divides this address space into 128 
segments, each with 128 KBytes. This hardware, called the Memory 
Management Unit (MMU), takes a logical address generated by the 68000 
and transforms it into a physical address indicating a position in 
RAM or I/O. The transformation involves relocation; therefore the 
physical location of a segment in memory is wimportant to a program. 
During the transformation, the MMU performs access checks so that the 
segment igs used only for its intended purpose. The access checks 
help insure that a runaway process does not destroy too much data 
before being caught. 


There are three physical address spaces: main memory, 1/0, and 
special I/O. The main memory can contain up to two megabytes of RAM. 
The I/O memory addresses all system I/O devices and expansion slots. 
The special I/O address space is teserved for the Boot ROM and MMU 
registers. It is used only when starting the machine and when 
modifying the contents of the MMU registers. 


SYSTEM MEMORY MAP 
Address Range Address Space Function 


$000000 = $LFFFFF rey Memory System Main Memory (RAM) 
2 oF 
go00000 = sooLFFF * L/o Slot 0 Low Decode 
' $002000 = SOO3FFF t/o Slot 0 High Decode 
3004000 = SO0SFFF 1/0 Slot 1 Low Decode 
ray ——s£ 3006000 = S007 FFF r/o Slot 1 High Decode 
“Ne  §008000 - SOO9FFF 1/0 Slot 2 Low Decode 
$00A000 - SOOBFFF 1/0 Slot 2 High Decode 


$xx0000 = $xx3FFF Special 1/0 Boot and self-test ROM 


§00C000 = SOOCFFF 1/0 Floppy disk controller shared memory 
$00D000 = SOODFFF 1/0 I/O Board Devices 


S00E000 - SOOFFFF r/o CPU Board Devices 
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THE SYSTEM BUS 


The system bus connects the CPU board, 1/0 board, and expansion 
slots, providing a simple interface between the various devices. 

When an address is put on the bus, a signal indicates the start of 
the cycle. The system then waits for the addressed device to respond 
with the acknowledge signal which marks the end of the cycle. Timing 
on the system bus is non-critical. The bus cycle can be as short as 
800 nanoseconds or as long as 50 microseconds. If the addressed 
device does not respond within 50 microseconds, a timer on the bus 
asserts the bus error signal. A detailed description of the System 
Bus timing is given in the section on the expansion I/0 slots. 


The following pages describe in detail the CPU board and memory 
management unit, the various built-in I/0 devices and interfaces, and 
the expansion slots. A discussion of the design of device drivers 
can be found in the Operating System Reference Manual. This manual 
is intended for programmers who deal directly with the hardware-~it 
igs not a service manual, nor does it provide a complete theory of 
operation. Complete schematics are included, however, in the 
appendices. 
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THE 68000 


The 68000 is a 16 bit microprocessor with eight 32 bit data registers, 
seven 32 bit address registers, a 32 bit program counter, and two 32 
bit stack pointers. Its instruction set directly supports a wide 
variety of data types and addressing modes. Its 24 bit address bus 
provides a memory addressing range of 16 megabytes. The 68000 used 
in the Lisa computer has a CPU clock period of 200 nanoseconds. 

Since the memory cycle time is 800 nanoseconds, and since the 
processor cannot access memory during video refresh cycles, enough 
wait states are inserted to bring each instruction execution time to 
a multiple of four cycles. 


INTERRUPTS 


The 68000 has a flexible interrupt handling structure. Interrupts are 
generated by system errors, program errors, and external devices. When 
the interrupt is detected, the 68000 enters the supervisor state and 
begins executing instructions at the address provided by the exception 
vector table. The source of the exception can provide the index into the 
vector table, or the interrupt level can be used to provide the exception 
vector (’autovectoring’). Internal Lisa devices all use autovectors. 
External devices can use either option. 


The interrupt system has seven fixed priority interrupts. 


FIXED PRIORITY INTERRUPTS 
Type 


Non~Maskable Interrupt (highest priority) 
- RS-232 ports 

Expansion slot 0 

Expansion slot | 

Expansion slot 2 

Keyboard Interrupt 

All other internal interrupts (lowest priority) 
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EXCEPTION VECTOR ASSIGNMENT 
Exception Vector Address 


Reset: Inital SSP $000000 

Reset: Initial PC §000004 

Bus Error $000008 

Address Error $00g0ooc 

Illegal Instruction §$Q00010 

Zero Divide §000014 

CHK Instruction _ $000018 

TRAPV Instruction soodolc 
Privilege Violation §000020 

Trace $0000 24 
Unimplemented Instruction 1010 $000028 
Unimplemented Instruction LL11 $00002C 
Reserved, unassigned §000030 - so0cd5r 
Spurious Interrupt §000060 

Other Internal Interrupt §000064 

Keyboard Interrupt $000068 

Slot 2 Autovector $00006C 

[Slot 1 Autovector $000070 

Slot 0 Autovector $000074 

RS232 Interrupt $000078 
Non=Maskable Interrupt $00007C 

TRAP Instruction Vectors $000080 ~- sOO00BF 
Reserved, wiassigned . gs0000CO - SQOCOFF 
User Interrupt Vectors $000100 = SOOO3FF 


These addresses are logical addresses. The operating system stores the 
vectors in segment 0, context QO in main memory. 


Four sources can generate 2 Non-Maskable Interrupt: power fail, hard 
or soft memory error, and keyboard reset. Any key on the keyboard 
can be programmed to cause the keyboard reset. 


The floppy disk controller, the hard disk interface, and the video 
circuitry can generate level 1 interrupts. 


Although the power on reset vector is a part of the exception vector 
table given above, it is actually stored in ROM so that the vectors 
_are available at power on. 
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MEMORY 


All memory is divided into three parts: main system memory (RAM), 
I/O memory, and special I/O memory. Main memory can contain up to 
two megabytes of RAM. I/O memory is used by all system I/0 devices. 
Special 1/0 memory is used to boot the machine and to run the 
self-diagnostic tests. The Memory Management Unit transforms 
addresses generated by the 68000 into actual memory locations. 


MEMORY CONFIGURATIONS F 


The memory boards contain four rows of RAM chips with 18 chips in 
each row. This configuration provides byte parity memory. Since 

the chips can be either 16K or 64K RAMs, the board capacity is either 
128K or 512K bytes. The boards can be jumpered to reduce total 
memory capacity by stuffing only one or two rows. A partially 
stuffed memory board containing 64K RAMs can yield either 128K or 
256K bytes. 


The memory boards contain the address recognition circuitry to make 
them self configuring. Ann byte board automatically occupies the 
mext n bytes in the main memory address space. Memory capacity can 
therefore be increased merely by plugging in another board. 
POSSIBLE MEMORY CONFIGURATIONS 
Configuration Board 1 Board 2 Board 1 Total 
Number Chips Chips Size Size 
16K 128K 128K 


16K 128K 256K 
64K ‘ 256K 256K 


64K 512K 512K 


16K 128K Si2K 640K 
64K 512K 128K 640K 


64K 51a 256K 768K 
64K 256K 512K 768K 


64K : 512K 512K 1024K 


Since only four rows of RAM fit on a board, the maximum memory size is 
one megabyte. 
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THE MEMORY MANAGEMENT UNIT 


The Memory Management Unit (MMU) helps the Operating System relocate ~ 
objects in memory. It also provides memory access controls to 

prevent a process from accessing memory which is not assigned to it. 
The mechanism used is segmentation. 


The 68000 outputs 24 bits of address information. The seven mst 
significant bits (A423 ~- Al7) select one of the 128 segments. The 
remaining 17 bits are the offset into the segment. Each segment has 
two associated registers which describe the origin (SORG) and size 
(SLIM) of the segment. In addition, each segment is divided into 512 
byte pages. The most significant 8 bits of the segment offset 
determine the segment page number, and the remaining 9 bits are the 
page offset. 
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ADDRESS TRANSLATION 
Logical Address 


<- - ee Fee ew OS 
a 
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ene ent 
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| (8 bits) (9 bits) 
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I I 
| | 
| | 
re | 
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_ 
! Origin 1! | Logical page no | 
- tt 
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+——-> [+] <————+ 
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v 
Se os 
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an eeeeeneineeeneenenenennenneneD 


Physical Address 
(21 bits -—- 2 megabytes) 
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THE SEGMENT ORIGIN 


The Segment Origin Register (SORG) contains the high 12 bits of the 
address added to the segment offset produced by the 68000 to get the 
physical address. The register can be read or written. Its address 


ts Lana v 
. f ra ra 


i4 
beslt tile 
SSSSSSSx10 ‘ pe (in Special 1/0 space) 
a nf rhe 
where 0 3 
t . 


sssssss \” selects the segment 
x ignored 


2\ bar 


Bits 0 to ll of the register set the segment base address for segment 
SSSSSSS. The other 4 bits in the register are not used. For 
example, a segment whose origin is §000200 has SORGL1 - SORGO set to 
$001. ‘The address is in the currently selected context. The SEG1 
and SEG2 bits determine which context is selected. An MMU setup 
program should run in supervisor mode. 


CONTEXT SELECTION 


The context bits mentioned above permit fast context switching. The 
MMU has four sets of MMU registers which can be assigned to four 
different processes. Once these contexts have been loaded, the 
context bits can be used to control which context is active. 
Contexts 1, 2, and 3 are general purpose contexts, but context 0 is 
intended for the use of the Operating System. Whenever the 68000 
does an access in supervisor mode, the context is automatically 
switched to context 0. When the context selection bits are actually 
set, however, the fact that you are necessarily in supervisor mde is 
ignored and the desired context ig selected. The TRAP instruction, 
which puts the processor in supervisor mode, can be used to generate 
a call from a user process to the Operating System. 


The two bits SEGL and SEG2 control which context in the MMU is 
gelected. SEG1 is set by a read or write at the address S$OOEQOA (in 
I/O space), and reset by a read or write at $00E008. SEG2 is set by 
a read or write at $OQEOOE and reset at $0QE00C. The context 
selected is determined as follows: 


_SEG2 SEG] -Context 


0 
I 
0 
1 


0 
1 
2 
3 
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THE SEGMENT LIMIT 


When the MMU receives an address, the address is first relocated and 
an access to main memory is started at the addressed location. The 
MMU then checks to see that the relocated address is actually within 
the limits of the segment being accessed. 


LIMIT CHECKING 
Logical Address 


Keer 72 - < 
rr nent 
segment no. | offset 
eh 1 
l | logical page no | displacement 
{ | (8 bits) 1 (9 bits) 


SLIM7 - SLIMO 


| 
{ 
| 
| 


I 
i 
| 
Tl1l1 | 11001111 { 


limit failure if carry out = | - normal segment 
limit failure if carry out = 0 = stack segment 


The Segment Limit Register tells the MMU the segment limit and 
controls which address space is accessed. If the address is within 
the size limit of the segment being accessed and the access is to 
main memory, the cycle is completed. If the address is beyond the 
segment limit a bus error is generated. If the access required is 
actually to I/O space, the main memory cycle is terminated and the 
I/O cycle is performed. The four control bits in the limit check 
register tell the MMU which address space is being accessed. 
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The Limit Register of a particular segment is found at the address: 


SSSSSSSx1 0 xxxxxxxxxx020cx (in Special 1/0 space) 
where 


sssssss selects the segment 
x ignored 


The limit register is divided into three regions: 


15 12 11 87 0 
a te 


| ignored | access control | segment length | 
pn Ee eo 


. 

Ae 

iy Bits 0 to 7 of the limit register set the length of the segment. The 
value in these bits is interpreted as the segment length in two’s 


s’ >. complement form. A length of 0 (SLIM7 - SLIMO = $00) indicates—that 
? any access is allowed. A length of 255 (SLIM7 - SLIMO = SFF) 


indicates that the segment contains 512 bytes. 


y 


“Bits 8 to 1l of the limit register are the access control bits. 
ACCESS CONTROL BITS 


Address Space and Access 


Main memory -- Read only stack 
Main memory ~—- Read only 

Main memory —- Read/Write stack 
Main memory -— Read/Write 

I/O space 

Page invalid (segment not present) 
Special 1/0 space 


wide 


, 
i 
pe pws rt oe 
Koro 
tow 


\Oo00 
~~ oO 
TAA wh 


i 
| 


er O10 KH OO 


me 
-— 


any other Not allowed (umpredictable results) 


THE PROCESS STACK 


Before the 68000 pushes data on the stack, the value of the stack 
pointer is decremented. The top of the stack {fs actually at a lower 
address than the bottom of the stack. To permit a segment to start 
at the segment top and grow downward, one of the control bits (3) is 
used to reverse the map’s limit check. [t is assumed that the stack 
pointer is initialized to all ones + 1 in the segment. That is, it 
"gcarts" at the bottom (O0-th word) of the neighboring segment. Since 
its value is first decremented, the first actual location accessed is 
the top word of the segment. 
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LOADING THE MMU REGISTERS 


To set up the MMU, the Operating System must initialize the SORG and 
SLIM registers of each of the 128 segments. To set these registers, 
the memory map must be disabled. 


The MMU can be disabled by setting the SETUP bit. SETUP is set at 
power on when the map registers are uninitialized, and whenever the 
map registers are being loaded. When the memory map is disabled, the 
Special I/O address space is enabled, and only the MMU registers and 
boot ROM can be acessed. In this state the system hardware decodes 
addresses from the 68000 in the following manner: 


SPECIAL I/O ADDRESS DECODE 


23 22 21 20 19 18 17 1615 1413121110 9 8 7 6 5 4 3 2 1 ~0 
Om me Beene 
| segment mimber Ix [RIM | ROM address iS |x x x! 
nn ren fnnpe enrpenr n  mere renrenreeerereenenereeeesnnen en prea anasaremcnrs 


Bit 16 is ignored. Bit 14 (M) turns the memory map on (1) or off 
(0). If the map is off, bit 15 (R) selects either the system ROM 
(0), or an MMU register (1). If the ROM is selected, the low 14 bits 
are the address in ROM. If the MMU is selected, the high order bits 
are the segment number of the register to be accessed and bit 3 
determines whether the Segment Origin register p), or the Segment 
Limit register (J) is accessed. Bits 0 - 2 are unused. 


When the system is powered on, the SETUP bit is set. The power on 
vectors at address 0 are fetched from ROM and can branch to the boot 
program in the ROM. The boot program can be addressed by any segment 
number. It is recommended that segment 127 be programmed to decode 
special I/O and that the boot program jump to segment 127 when it 
begins execution. The boot program can initialize the MMU registers 
so that context 0 addresses RAM with the low 16 segments and systen 
I/O with segment 126. Since this makes all the address space in the 
system accessible, the system can act as though no memory map were 
present. The boot program can then turn off the SETUP bit, but the 
program can continue to run from ROM because segment 127 has been 
programmed to special I/O. The Operating System can then be loaded 
imto RAM and begin normal execution. 


When the Operating System wants to load the MMU registers, the 
program it uses must be located at a logical address that has bit 14 
set. If bit 14 is set and the program is in supervisor mode with the 
SEG bits set correctly, the SETUP bit can be set and the program 
continues to execute out of RAM as long as the address emitted has 
bit 14 set. When the actual write to the MMU register occurs, bit 14 
must be 0 and bit 15 must be set. Once the MMU has been set up, the 
SETUP bit must be cleared to return to normal operation. The SETUP 
bit can be set by a read or write at che address $O0E010 in 1/0 
space, and reset by a read or write at SOOEQ12. 
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MEMORY ERRORS 


Two kinds of memory error can be detected during a memory access, 
Hard Error and Soft Error. A Hard Error is a parity error during a 
parity memory board access or an umcorrectable error during an ECC 
memory board access. A Soft Error indicates that a correctable error 
has been detected on an ECC memory board access. If either the Hard 
Error (HDER) or Soft Error (SFER) signal is asserted at the end of 2 
memory cycle, a latch on the CPU board latches the address at which 
the error occurred, and asserts the NMI signal which interrupts the 
68000. The address latches latch the high order 16 bits (segment 
number and page number) of the address. The cause of the error is 
latched in the system status register. A program can therefore log 
soft errors in ECC boards and keep track of hard failures in main 
memory on a page by page basis, and the MMU can be used to map out 
bad pages. 


Detection of either hard or soft memory errors can be disabled. Each 
error type has an Enable Memory Error Detect Bit. If the bit is set, 
errors are detected and latched. If the bit is reset, error 
detection is masked. At power on, both kinds of memory error 
detection are masked off. To set soft error detection, read or write 
to the address $OQOEQ16 in I/0 space. To reset soft error detection, 
read or write to SOQEQ14. Hard error detection is enabled by a read 
or write to SQOEQLE, and disabled by a read or write to $O0EQIC. 
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THE STATUS REGISTER 


The status register permits a program to read the status of the 
system bus. A Bus Error exception routine can read this register to 
determine the cause of the Bus Error. The register is located at 
$SOOF800 in I/O space. It can only be read. Its bits have the 
following meanings: 


STATUS REGISTER BITS 


Bit Name Meaning 


Soft Error A soft error has occurred (bit=0) i 


Hard Error A hard error has occurred (bit=0) 


Vertical Retrace The video circuit has begun a vertical 
retrace if this bit is a0. When this 
bit is set, an interrupt is generated. 
The interrupt routine should reset this 
bit just before it returns because the 
video circuit continues to set this bit 
for two scan lines after the start of the 
retrace (about 90 uS). The. Enable Vertical 
Retrace'Interrupt bit can be set to mask 
the interrupt and prevent this bit from 
being set. 


Bus Timeout A bus timeout has occurred (bit=0). A 
timer insures that the 68000 does not 
hold Address Strobe (AS/) low longer than 
50 uS to keep the system from being hung 
by an attempt to access a nonexistent 
peripheral device. Whenever the timer 
detects that AS/ has been low for more 
than 50 uS, a Bus Error is generated and 
the Bus Timeout bit is set in the system 
Status register. 


Video Bit This bit permits the CPU to read the output 
of the video circuit for diagnostic purposes. 
If the Video Bit is 1, the video output is 
a bright spect on the screen. 


Horizontal Sync This bit permits the CPU to read the state 
of the horizontal syne signal for diagnostic 
purposes. When the bit is 1, the display 
is in a horizontal retrace. 
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Serial Number Data The serial number is stored in the video 
state PROM as a 56 bit number. It can te 
page cee" read one bit at a time at this location. 
The serial mimber is delivered one bit 
every four CPU clock cycles, so a program 
that does consecutive memory cycles at the 
maximum rate can read one bit per cycle. 


Serial Number Sync The serial number read out into bit 6 is 
synchronized to start when the Serial Number 
Syne bit is 1. The following 224 CPU 
clock cycles shift out all 56 bits of the 
serial number. 


8-15 Unused 


THE MEMORY ERROR ADDRESS LATCH 


The memory error address latch can be read to determine the address at 
which a detected hard or soft error occurred. If the status register’s 
hard or soft error bits are not set, the address latch contains an 
indererminate value. Once the error logging program has read the 
lateh, the latch is reset to permit detection of subsequent errors. 

At the same time the soft error bits, the bus timeout bit, and the 
vertical retrace bit are reset. The address latch reset signal 

also gates the latched address data onto the data bus, so ali the 
status bits are reset when the error latch is read. The latched 
address is a physical address. The error address latch is located 
“xE$00F000 in I/O space. To teset the hard error bit, use the hard 
error mask bit. ~ 


MEMORY DLAGNOSTIC MODE 


Two flip-flops are provided to help test the error detection and 
correction circuitry. DIAG] asserts the Soft Error line, and DIAG2 
asserts the Hard Error line. DIAGl is set by a read or write to 
$OOE002 in I/O space, and reset by a read or write to $00 E000. 
DIAG2 is set by a read or write to SOQE006 and reset by a read 

or write to SOOE004. 
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The test function performed depends on the type of memory board in use. 
On a parity memory board, the parity detection circuitry can be tested 


by the following steps: 
1. Assert the Hard Error line (set DIAG2) 
2. Write to memory 


3. Clear DIAG2 


4. Enable dard Error 


At this point a read from the memory board should generate a parity error. 
Since the Hard and Soft error status latches are set in this mde, the 
Hard and Soft error masks should also be set. 
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VIDEO CIRCUIT 


The display is 6.325 inches high and 8.5 inches wide. There are a total 
of 374 herizontal lines of which 360 are active. 720 of the 886 vertical 
lines are active. There are, therefore, 259,200 active elements in the 
full display. 


The dot clock frequency is 20.0 MHz, so the dot clock time is 50 nanoseconds. 
The active line time (the dot clock time times 720) is 36 microseconds, 

and the inactive line time (dot clock times 176) is 8.8 microseconds. The 
line frequency is 22,321.429 Hz. The frame frequency fs 59.68 Hz. The 
screen aspect ratio (width/height) is 4/3. The dot aspect ratio is 2/3. 


THE VIDEO DISPLAY 


176 
ooTs 
(11518) 


Active Video 
Area 


Number of Active Dispiay Elements 
720 x 360 = 259,200 
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The video circuit fetches a 16 bit word from main memory once every four 
CPU clock cycles, and shifts it out to the CRI to provide a bit mapped 
display. The data in the bit map is displayed as an image of the bits 

in memory. A ome corresponds to a dark (off) dot, and a zero corresponds 
to a bright (on) dot. Wait states are inserted into each memory fetch 

so that it takes a mulciple of four cycles. 


A periodic interrupt, the vertical retrace interrupt, is generated at the 
start of each vertical retrace. The display is refreshed ac 60 Hz. 

A state machine in the video circuit counts the oumber of words 

displayed and generates the horizontal and vertical sync pulses. 

The ROM which controls this state machine also contains the system 

serial mumber. 


The vertical retrace interrupt can be disabled. A write to the address 
SOOEOLA in I/O space enables the interrupt and a write to SOOEO18 disables 
the interrupt. Since the Reset line resets ‘this bit, the vertical retrace 
interrupt is masked off at power on. 

_The video circuit controls the low order 15 bits of the video address 
to refresh the display. The high order six bits remain fixed. The video 
address latch at $OQ0E800 in the 1/0 address space provides the high order 
six bits. By writing to this register the programmer can position the 
video memory anywhere in main memory. At power on the register is in an 
indeterminate state. 


DIS - D6 D5 D4 D3 D2 
Cn nn ee a tnIEZnEnEnEE AIRES Aum REERnenah dmmatnemena 
unused 1 VA20 | VAIS {| VAL8 | VAL7 | VAL6 { VAL5 | 
pe a oe 


CONTRAST CONTROL 


The contrast control circuitry is located on the I/O board. A 
digital to analog converter controls the CRT display contrast. This 
converter is controlled by a latch connected to the Slow Data bus 
(the hard disk interface 6522 Peripheral A Port). To write a value 
to the contrast latch: 


Set the DEN bit (PB2) to l. 


Put the desired contrast value ($00 to $FF) on the Peripheral 
A Port of the hard disk 6522. 


Execute MOVE.L DO,SOODO1C. This instruction causes a pulse 
on the contrast latch clock input. 
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The address SOQOQDOIC in the I/O address space clears the clock input to 
the contrast latch. The address $QQDOLE sets the clock input, so the_ 
MOVE instruction given above insures that there is a positive edge on 

the clock inputc. 


When the system is reset either by the RESET instruction, or by a 
power-on, the contrast latch is reset and the screen is cleared. The 
higher the number stored in the contrast latch, the higher the 
display contrast. 
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SYSTEM BUS TIMING 


Address taan- aa ) WLLL HLL 


AS 


UDS or LOS 
t 
Read Cycie write Cycie = ‘psetuo — 


Data Out (wine) LLL, TT 


Data In (neaa] LLL KN RL 
Select (SC, or Sha) 
READ 


DTACK 


Cycle Time 800ns 
TASetup 100ns 
TDSetup 100ns 
TFinish 100ns | 260ns 
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MEMORY BUS TIMING 


Video Cycle CPU Cycle 


pmcktaes ee 


Resa 
RAS Fe en tee a 
She ee 


pata out = LLL 
Datain “= WLLL TCC 


trom RAM 


en 
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A SUMMARY OF 
1/0 SPACE LOCATIONS 


Status Register $00F800 
Memory Error Address Latch $00 FO00 


Memory Diagnostic Bits 
DIAG] Set: $O0E002 
Reset: $00 E000 
DIAG2 Set: $00 £006 
Reset: $00 E004 


Context Selection Bits 
SEG1 Set: SOOEOOA 
Reset: $OOE008 
SEG2 Set: SOOEOOE 
Reset: SOOEOOC 


SETUP register Set: $00EDLO 
: Reset: $SOOEO12 


Enable Vertical Retrace Interrupt 
Set: SOOEOLA 
Reset: $SOOE018 


Enable Memory Error Detect 
Soft Error Enable 

Set: SOOEQ16 

Reset: SOOEO14 
Hard Error Enable 

Set: SOOEOLE 

Reset: SOOEOLC 


Video Address Latch $00 E800 
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THE INPOT/OUTPUT BOARD 


The Input/Output board contains the circuitry for the 1/0 devices built 
into the Lisa. These devices are: 


Keyboard/Clock interface 
Two Serial interfaces 
Floppy Disk Controller 
PIPPIN Hard Disk Controller 
Speaker and CVSD interface 


The soft-on and soft-contrast registers are also on the I/0 board. 


I/O devices are accessed through memory~mapped locations in 1/0 address 
space. 


THE KEYBOARD INTERFACE 


The keyboard interface uses two Control Oriented Processor System 
(COPS) microprocessors. The COPS on the keyboard communicates key up 
and key down information to the 68000 over a bi-directional serial 
interface. The other COPS is on she 1/0 board. It connects the 
bi-directional keyboard signal to the 68000 by way of an eight bit 
parallel port implemented with a 6522 Versatile Interface Adapter. 


Since the same circuitry which is connected to the power-on pushbutton, 
the power supply ON signal, and the power fail signal, also supplies 
the clock/calendar function, it is possible for software to cause 

the system to turn itself off and on. 
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The 6522 has two eight bit parallel I/O ports (Peripheral A Port, 
or PAO=<PA7, and Peripheral B Port, or PBO~PB7). The control lines 
for these ports are CAl, CA2, CBl, and CB2. The bit assignment 
is as follows: 


6522 Peripheral A Port 


TERED INEEEEIEREE mmeeeeane meeeeeamnae: eeeeeneeen teeeemeeeeee ieeecenemaees eee 

| CD7 | CD6 | CDS | CD4 | CD3 | CD2 | CDL | CDO | Lisa Name 

T  eEIREI IRIEL Enna oeeeeeae ameencet enone oe ener ne 

‘PA? PA6 PAS PAS PA3 PAZ PAL PAO Synertek Name 
& 


CDO - CD? Data bus for communication with the COPS. 


Cal CAL must be programmed as an input that latches the 
COPS data in the Peripheral A Port. 


CA2 CA2 must be programmed to handshake with the COPS 
to indicate that the data has been latched. 


6522 Peripheral 3B Port 


ce fence 
| CR/ { CRDY | PR/ | FDIR | VC2 | VCl | VCO | ENC | Lisa Name 
ST eed 

PEG PB85 PB4 PBS Synertek Name 


ENC controls the CVSD Encode/Decode line. When 
ENC is high, the CVSD circuit is in encode mode. 


These bits control the speaker volume. When all 
three bits are low, the speaker is at its lowest 
volume. As the three bit mumber formed by 

VCO to VC2 increases in magnitude, the speaker 
volume increases. 


Floppy Disk Interrupt Request. Before attempting to 
vead from the memory shared by the 68000 and the disk 
controller, it is necessary to insure that the 
floppy disk controller is the source of the level 1 
interrupt. If it is not, the attempted memory 

access would disturb the disk operation in progress. 
The FDIR input allows the disk interrupt line to be 
sensed to check this condition. If FDIR is 1, the 
controller is the source of the interrupt, so the 
68000 can safely read the shared memory. 
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PR/ Parity Reset (low true). PR/ resets the parity latch 
in the hard disk controller. It should be pulsed low 
before each disk data transfer so that any parity : 
errors which were detected during the data transfer 
can be passed on to the disk driver. If CR/ (PB7) 
is high, PR/ is an input from the parallel port. 


COPS Ready. This signal wmdergoes a high to low 
transition when the COPS is ready to accept 2a 
command (see the timing diagram below). There 
is no handshake on entering a command. 


Controller Reset. When CR/ is low, you can reset the 
Pippin Controller connected to the hard disk port. 


CBl is used to clock data transfers between the 6522 
Shift Register and the CVSD circuit under the control 
of T2. 

CB2 is a data I/O pin between the 6522 Shift Register 
and the CVSD circuit. 


COPS COMMAND TIMING 


eke 
CROY ie 


! 
COD-CO? YY YL Sat 189 oma vais YL 


oc a 


Min | Max 

a enn 
CRDY Width l6us | 20us 
TSetup ~8us | l5us 
THold 20us | 50us 
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6522 REGISTER ADDRESSES 

Register Reg# Register Function Address 

ORB/ IRB Output/Input Register B §00D181 
Output/Input. Register A $00D1L83 
Data Direction Register B SOODL85 
Data Direction Register A §00D1L87 
Tl Low-order Latches/Counter $00D189 
Tl High-order Counter s0OD1L8B 
Tl Loweorder Latches sooDl8D 
Tl High-order Latches sooDlL8Fr 
T2 Loweorder Latches/Counter sooDL91L 
T2 High-order Counter §00D193 
Shift Register §00D195 

. Auriliary Control Register $00D197 
Peripheral Control Register SOODL99 
Interrupt Flag Register — SOOD19B 
Interrupt Enable Register $00D19D 
Same as Register 1 but without 
handshaking : SOODI9F 


WOnAMW FW NFO 


Register 15 should be used when transferring commands to the COPS. 
All the 6522 register addresses are in the I/0 address space. The 
Tl timer in the 6522 is reserved for use as an interval timer by the 
Operating System. For further details about the 6522, read the 6522 
data sheet in the Synertek MOS Data Catalog. 


Page 29 
“LisaHWG81_029.PICT” 112 KB 1999-02-20 dpi: 72h x 72v pix: 2035h x 3032v 


@ Apple Lisa Computer Technical Information Page 0031 of 0083 


@ Apple Lisa Computer: Hardware Manual -- 1981 


Confidential " Lisa Hardware Reference Manual 


The CD bus (bits CD0 to CD7 above) can send commands to the COPS. 


CD COMMANDS 


CD7-cD0 Function 


0000 0000 Turn I/O port on 
0000 0001 Turn I/O port off 
0000 0010 Read clock data 
0001 nnnn Write nnnn to clock 
0010 spum Set clock modes (see Clock below) 
0011 onnn Write nnnn to low indicator bits in keyboard 
0100 Write nnnn to high indicator bits in keyboard 
0101 Set high nibble of NMI character to nonnn 
0110 ‘ Set low nibble of NMI character to anna 
lxxx Do nothing (mull command) 
If the 6522 is not programmed as an output when the CRDY line 
makes a high to low transition (thereby indicating that the COPS 
is ready to accept a command), the pullup on the CD bus prevents 
@ spurious command from being entered. 
The pin description given above indicates that the CD bus (the 
Peripheral A Port) should be set up to handshake and to latch data. 
Tf the 6522 is set up correctly, when the 1/0 board COPS has data 
for the 68000 it will handshake with the handshake lines and 
generate an interrupt. 
The indicator bits can be used to control 8 LEDs. If, for example, 


these LEDs are installed on the keyboard, they can be used to emulate 
a VT-100 terminal. 
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RESET CODES 


In addition to the key up and key down information, the keyboard COPS . 
produces several two byte reset codes. The two bytes consist of a 
reset character ($80) and a code number for the following conditions: 


Reset Code Condition 


eens a SE a AE TE TL SS PS 


FF Keyboard COPS failure detected 
FE I/O board COPS failure detected 


FD Keyboard unplugged. The reset code of the 
keyboard ID will follow when the eiart is 
plugged back in 


Clock timer interrupt 
Soft power switch pressed (do a Soft-off) 
Reserved for future use 


Clock data follows (five bytes). "“y" is the 
year. Clock information is formatted, 


$80 SEy dd dh hm os st 


where ddd is the day, hh is the hour, m is 
the minute, ss is the second, and t is the 
tenth of a second. 


Keyboard ID number (the current and only 
keyboard ID is 01). The keyboard ID reset 
code ig produced whenever the keyboard COPS 
is reset. This happens when the power is 
turned on and when the keyboard is plugged in. 
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THE KEYBOARD 


The keyboard connects to the computer through the jack on the lower 
right front of the Lisa. Its 80 keys are fully programmable. 


The keyboard contains a microprocessor which scans the keys and 
communicates the occurrence of a key depression or release to the 
68000. The keyboard is a true N-key rollover design. An arbitrary 
number of keys can be depressed without causing phantom key problems. 
It is the responsibility of the 68000 side of the interface to 
interpret key up and key down codes to properly handle functions such 
as shift and automrepeat. Any key can be programmed to generate an 
NMI (non-maskable interrupt). 


The keyboard’s microprocessor contains an eight byte FIFO that 
buffers keyboard data if the 68000 does not collect it fast enough. 
Normally, this FIFO keeps keycodes from being lost, but if the 
keycodes are not read for a long enough time, the buffer will 
eventually overflow and keycodes will be lost. 


KEYCODES 

Seven bits of the keycode byte identify the key which moved. The 
other bit indicates whether the key went up or down. The keycode 
format is: 


drrr nnnn 


If the d bit is 0, a key up transition has occurred. If it isl, 
a key down transition has occurred. 
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The err and onnn bits of the keycode have the following meanings: 


rrr-> 


Page 33 
“LisaHWG81_033.PICT” 63 KB 1999-02-20 dpi: 72h x 72v pix: 1992h x 3065v 


@ Apple Lisa Computer Technical Information Page 0035 of 0083 


@ Apple Lisa Computer: Hardware Manual -- 1981 


, Confidential Lisa Hardware Reference Manual 


THE MOUSE 


The mouse is an input device with motion sensors and one or more 
buttons. It sends movement and button information to the computer 
through the 6522 on the keyboard interface. This information is 
usually used to provide a fast and convenient pointing and drawing 
mechanism by tracking the mouse movement in some direct manner with a 
cursor on the screen. 


The mouse is plugged into the nine pin EIA connector in the middle of 
the connector panel on the back of the Lisa. Since the mouse senses 
the mechanical movement of the ball as it rolls across a table, it 
should work on almost any convenient surface. 


MOUSE CONNECTOR PINOUT 


Switch L No connection : 

+5v Switch 0 (always grounded by mouse) 
Ground Down 

Left Up 

Right 


MOUSE COMMANDS 


Mouse commands are sent to the 6522 Peripheral A Port data bus 
(PAO=PA7). The command format is: 


O111 ennn 


If e is set, mouse interrupts are enabled. The nnn bits set the 
time interval that will separate mouse interrupts. 


Once mouse interrupts are enabled and the time interval has been set, 
the COPS interrupts the 68000 whenever the mouse moves. The time 
between interrupts is about 4 ms times the number given in the nnn 
bits. For example, the command 01111100 ($7C) enables the mouse to 
interrupt 16 ms (100 = 4*4 ms) after the mouse begins to move. If 
the mouse continues to move, interrupts are generated every 16 ms. 
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MOUSE DATA 


Mouse generated data is sent to the 68000 in three bytes: 


00 (mouse data follows) 
dx (change in X direction) 
dy (change in ¥ direction) 


The dx and dy values, which are in the range of -128 to 127, are 
reset every time the 68000 reads them. While the mouse is moving 
and mouse interrupts are enabled, a new dx and dy value can be 

read every non*4 ms. If the 68000 does not respond to the mouse 
interrupt and read the mouse data, the dx and dy values are updated 
and collected in the interface’s eight byte FIFO buffer. If the 
mouse is ignored long enough, the buffer will overflow, and mouse 
data will become invalid. 


The mouse button is returned as keycode d000 0110. If the d bie is 
1, the button has been pressed, and if the d bit is 0, the button has 
been let up. The d bit in the keycode d0O0O 0101 is 1 if the mouse is 
plugged in, and 0 if it is not. The third mouse "keycode" (4000 
Oll1) is eurrently unused. 
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THE CLOCK/CALENDAR CIRCUIT 


The clock/calendar is a part of the keyboard encoder circuitry. The 

clock resolves to tenths of a second, and needs to be reset only once 

every sixteen years. In addition, there is an alarm clock that can be VLA 
programmed to generate an interrupt at any time up to SFFFFF seconds 

(about 12 days) from the time it is set. This interrupt, for example, 23|.27 hom 
can be programmed to generate a system power up. 


The 6522 Peripheral A Port data bus (PAQ=PA7) is used to communicate 
with the clock. 


CLOCK COMMANDS 


PA7=PA0 Function 


. 0000 0010 Read clock data 
0001 nonnn Write nnonn to clock 


0010 spmm Set Clock modes 


CLOCK MODES 


Function 


nce et re ee a AE 


Clock/Timer disable 

Timer disable 

Timer underflow generates interrupt 
Timer underflow turns system_on, if it 


is off, and generates an interrupt 


If the p bit above is 0, the system is turned off. If the p bit ts one, 
and the system is off, the system is turned back on. 
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SEITING THE CLOCK 


The s bit, if set, enables Clock Set mode, and the 16 nibbles of 
time data can be entered one digit (nibble) at a time. Only as 
many nibbles as desired need to be entered during the time setting 
operation. Once the time has been set, the s bit 1s cleared, and 
the operation is terminated. The clock and timer must be stopped 
while the time is being set. To do this, set the clock mode to 
Clock/Timer disable ($00) during the operation, then reset it to 
Timer disable ($01) when the operation is complete. The clock 
can be left running while setting the alarm, but the timer must be 
disabled ($01). 


The order in which the time information is entered during the time 
set operation is: ’ 


asaaay ddd them ast (8 bytes total) 
where: 

alarm nibbles (0-$FFFFF) (0o- 04 8545) 

year (0-15) 

day (1-366) 

hour (0-23) 

minute (0-59) 

second (0-59) 

tenth of second (0-9) 
The alarm counts down one count per second and generates an interrupt 
upon the $00000 => S$FFFFF transition. Since the five alarm nibbles are 
entered first, the alarm can be set without disturbing the clock. 
All the nibbles are maintained in decimal format except the alarm 


and year nibbles which are kept in binary format to reduce the 
amount of code required to handle then. 


Note: Alarm setting corresponds te $.VNows ing ties! 


), 049 545 Seconds 


4, 436,29 harauctes 
14 /, 1... hours 


120! 4-- days 
73. weeks 
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THE CVSD AND THE SPEAKER 


The Lisa has a built-in speaker, and a circuit that performs 
digital-to-analog and analog-to-digital conversion. On the back of 
the Lisa is a microphone input jack, and a remote speaker jack. 


The 6522 which controls the keyboard interface also controls the 
circuit which drives the speaker. The circuit uses a Continuously 
Variable Slope Deltamodulator (CVSD) to provide both audio input and 
output. The central part of the circuit is a Motorola 3417 CVSD 
chip. 


The CVSD chip records and plays back audio data at a programmable 
rate. CVSD inpuc can come from a microphone plugged into the back of 
the Lisa mainframe. The length of the recording depends on the 
amount of memory available for it. Since the normal CVSD speed is 
16,000 bits/second, even a short recording can require a substantial 
amount of memory. CVSD output can be sent to the internal speaker, 
or picked up at the remote speaker jack. 


To record a signal, the ENC bit (PBO of the 6522) is set high. To 
play back a signal, the ENC bit is set low. The T2 timer (one of the 
6522 internal registers) is then set to produce the desired clock 
speed, and data is read or written (played or recorded) to the 6522 
shift register. The 6522 can be programmed to generate an interrupt 
whenever the shift register is full or empty. CBl clocks the data 
transfers between the 6522 shift register and the CVSD. 


The volume of both the CVSD and the speaker output is controlled by 
the three VC bits (PBl, PB2, and P33 in the 6522). The volume is 
proportional to the magnitude of the 3-bit unsigned integer formed by 
the VC bits. 


In addition to handling voice 1/0, the CVSD can be programmed to 
produce tones from the speaker. The CVSD represents a waveform as a 
series of 1’s and 0’s where al indicates a rising signal, and a 0 
indicates a descending signal. A series of alternating 1’s and 0’s 
therefore produces no sound at all. When its comparator indicates to 
the CVSD that the signal has been rising faster than the rate at 
which the CVSD has been rising for several samples, the CVSD 
increases the slope of its signal. This continuously variable slope 
enables it to produce a closer approximation of the desired waveform 
than a simple slope modulator can. Of course, the quality of the 
approximation depends on the rate at which the waveform is sampled. 
The higher the sampling rate, the better. See the Motorola MC3417 
data sheet for full details. To send a pattern to the CVSD, load the 
shift register and program the T2 timer to produce the desired 
frequency. The resultant waveform need not be a square wave. 
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THE SERIAL INTERFACES 


The Lisa has two built-in RS232-C serial communication ports. Both 
ports can support local asynchronous commmuications at speeds up to 
19.2 Kbaud. In addition, port 1 conforms to RS232-C type D 
specifications, permitting full modem control with either synchronous 
or asynchronous protocols. 


The serial logic is implemented with a NEC 7201 dual channel 
communication interface. Refer to the 7201 data sheet for complete 
information about the operation of the chip. Note that autovectors 
are used so you de not need to program the 7201 to supply the 
interrupt vectors. 


The 7201 has neither an internal baud rate generator, nor a Ring 
Indicator input. The baud rate generator is provided by the serial 
interface. The Ring Indicator input is brought into the channel B 
DCD (Data Carrier Detect) line where it must be decoded by software. 
The DCD line can be programmed to produce an interrupt whenever there 
is a transition on that line. 


SERIAL INTERFACE LINES 


Signal Name Description RS-232 Pin # 
Channel A Channel B 


Transmit Data 
Received Data 
Request To Send 
Clear To Send 
Data Terminal Ready 
Data Carrier Detect 
Ring Indicator 
Transmit Clock Input 
Receive Clock Input 
Transmit Clock Output 
DSR Data Set Ready 


alli tlSteun 


Both channels are set up to be the Data Terminal Equipment (DTE) end 

of the communications system. To connect other DTE devices to the Lisa, 
you need a modem eliminator (a mull modem). The Apple /// mull moden 
(590-0029-00) with a communciations card cable can be used to connect 
the Lisa to a Qume printer through channel B. 
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BAUD RATE GENERATION 


The baud rate generator produces standard baud rates as well as a 
baud rate that is under the control of the 6522. The 6522 controlled 
rate can range from less than one baud up to about 1000 baud. Since 
the Tl timer in the Hard Disk Interface’s 6522 is connected to the 
baud rate generator via PB7, either data communications channel can 
use the 6522 timer for baud rate control. The baud rate generator 
has seven control line inputs (cO-C6) which are_set or reset by 
control pulses. 


BADD RATE CONTROL LINES 
Channel 1 


ccc Baud Rate 
210 
ene 
000 External Clock 
001 6522 control 
010 300 baud 

oll 1200 baud 

100 2400 baud 

101 4800 baud 

110 9600 baud 

lll 19200 baud 


Baud Rate 


6522 control 


001 00 baud 
010 600 baud => 
0 00 baud 


100 2400 baud 
101 4800 band 
110 9600 baud 

19200 baud 


Receiver Clock 


same as transmitter clock 
external clock (for synchronous communications) 
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Control Bit Addresses 
Bit Set Address Reset Address 


co $00D002 $00D000 
cl $00D006 §00D004 
c2 §00D00A $00D008 
c3 SO0D00E go0gDp00c 
C4 $00D012 $00D010 
cs $00D016 g$oono14 
c6 sogDolAa s00D018 


7201 Register Addresses 


Channel 1 Data: $00n041 
Control: $00D045 
Channel 2 Data: $00D043 
Control: $00D047 


Note that the 7201 baud clock is at 16 times the baud rate in all the 
cases given above. For 9600 baud, for example, the clock runs at 
153.5 KHz. It is possible to program the 7201 to use the xl clock in 
synchronous communications, so baud rates up to 307 Kilobaud are 
possible. 
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THE FLOPPY DISK CONTROLLER 


The built-in floppy disk controller consists of a 6505 based 
microcomputer and a disk interface similar to that of the Apple II. 


The 6505 has 1 KByte of RAM and 4 KBytes of ROM. The RAM is shared 
with the 68000 address space. The 68000 and 6505 communicate data 
and commands through this shared memory. Use the MOVEP instruction 
to convert 16 bit 68000 data to the 8 bit 6505 format. When data 
moves from the 6505 to the 68000, the shared memory appears in the 
low byte of each word read by the 68000. 


At power on, the 6505 sets the disk control lines to a safe state, 
does a checksum on the ROM, tests the RAM, clears some of the RAM, 
and leaves the results of the ROM and RAM tests in the location 
$00C003. The 6505 then interrupts the 68000 and waits for a command. 


DISK CONTROLLER COMMANDS 


The command block consists of 20 bytes in the low 20 words of the 
6505 address space. 17 of these bytes are used to pass parameters 
to the Read/Write/Track/Sector (RWIS) routine. The other 3 bytes 
are used for communication between the 68000 and the 6505. The 
command byte appears at the 68000 address SOOCO01, and at the 6505 
address $0000. 


The disk controller reads the command byte until a valid command 
appears, or until an interrupt arrives from the disk drives. The 
disk drives generate an interrupt when the eject button is pushed 
and when the disk is in place. When a valid command appears, the 
controller reads the command, clears the command byte, executes the 
command, and interrupts the 68000 if necessary. The controller then 
waits for the next command. 


FLOPPY DISK CONTROLLER COMMANDS 
(68000 writes to $00C000) 


Execute RWIS using SO00CO003 =~ §00C031 as parameters 
JSR to routine pointed to by $00C003 and s00C005 
Clear Interrupt Status 

Set Interrupt Mask 

Clear Interrupt Mask 
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When the 6505 generates an interrupt, the 68000 receives it as a 
level 1 interrupt. The 68000 can discover the state of the floppy 
disk interrupt request line by reading the location PB4 (also known 
ag FDIR) in the keyboard’s 6522. I£ this bit is low, the floppy disk 
controller has interrupted the 68000, so the 68000 can examine the 
shared memory area to determine the results of the command. The 
68000 should check the FDIR bit before accessing the shared memory 
because the 6505 locks the 68000 out of the shared memory during a 
disk transfer. If the 68000 cries to access the shared memory while 
it is lecked out, a Bus Timeout Error occurs. 


THE EXECUTE RWIS COMMAND 


The main part of the code in the disk controller ROM is executed by 
the Execute BNTS command ($81). The routines involved are very 
similar to those used by DOS 3.3 (see the DOS 3.3 Manual, Apple Part 
No. w.ocococx). As in DOS 3.3, an I/O Block (IOB) is used to pass 
patameters to the RWIS routines. 


FLOPPY DISK I/O COMMAND BLOCK 


$00C003 Command code 
$00 Seek 
$01 Read 
$02 Write 
$03 Reserved - 
$04 Format 
$05 Clamp 
$06 Examine status 
$07 Unclamp 
$00co05 Drive select 
$00 Drive 2 (Bottom drive) 
$380 Drive 1 (Top drive) 
$00C007 Side select 
$0x Side 1 (Top side) 
$lx Side 2 (Bottom Side) 
$00c009 Sector number (0 to 22) 
$00CO0B Track number (0 to 44) 
§00COO0D Error code 
$00 No error 
$40 Drive error 
$OO0COlL1 Version number (2 bytes) (Operating System Header) 
$00C015 Volume number (2 bytes) 
$00C019 File ID (2 bytes) 
§O00COLD Data used (2 bytes) L 
$00C021 Absolute page (2 bytes) “Taq tes (12) 
$00C025 Relative page (2 bytes) 
$00C029 Forward link (2 bytes) 
§00C02D Backward link (2 bytes) 
$00C031 Previous drive number (drive accessed on last command) 
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The I/O Block controls the transfer of data from the 6505 to the 
disk. The transferred data is in a buffer located at $00csoL = 
SOOC7FF on the 68000 side and at $0200 - SO3FF on the 6505 side of 
the shared memory. The 68000 can use the MOVEP instruction to. 
transfer this data from the shared memory to its main memory. 


DISK DATA STORAGE Fonrammer’s Apel 


MAC Source book 
Data is stored in 512 byte blocks on the floppy disk. The number of ton Coe we 


blocks in a track depends on the track mumber. A block is equivalent { 
to a DOS 3.3 sector. ‘The total capacity of each side of the disk is 
868 blocks or 444,416 bytes. . <i 
“Twigg taook Floff% es 
Track number Blocks in track TEATS Secste See 


O-1§ — 12 — (0-19) 
oan ——{}92 -367) 
ajdt (aso ey 


ag-63 —9 U2 -6n) 
64-79 —@ —(67-777) 


[K ee he) ot bset trom on 
gecko ; 


The JSR command ($84) transfers control from the normal BWTS routines 
to another program. This program can be located in the ROM, or can be 
downloaded into the shared memory and then executed. The two bytes 
after the command byte ($00C003 and $00C005) contain the low and high 
bytes of the address of the program to be executed as seen from the 
6505 side of shared memory. To calculate the 6505 address, shift the 
68000 address right one bit, then mask off the high order 9 bits. 


THE JSR COMMAND 


INTERRUPTS 


The Clear Interrupt Status command ($85) clears the interrupt line 
from the 6505 to the 68000 using a mask found at SO0CO03. A one in 
the mask byte clears the associated interrupt bit. Several interrupt 
sources can cause the 6505 to assert the FDIR/ bit. The identity of 
the interrupt source can be found at $00C081. 
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FLOPPY CONTROLLER INTERRUPT SOURCE 


Set if D6, D5, or D4 is set 

Set if RWIS is complete for Drive 1 

Set when the Drive 1 Button is pushed 
Set when Drive 1 signals "disk in place" 
Set if D2, Dl, or DO is set 

Set if RWIS is complete for Drive 0 

Set when the Drive 0 Button is pushed 
Set when Drive 0 signals "disk in place” 


The 68000 can clear any of the bits in this word with the Clear Interrupt 
Status command. D7 and D3 remain set as long as any associated bit is set. 


The Interrupt Mask byte at $00C083 determines which drive can interrupt 
the 68000. Only bits 7 (Drive 1) and 3 (Drive 0) are used. The Set 
Interrupt Mask command ($86) sets the bits of this mask on the basis 

of the operand byte at $00C003. The Clear Interrupt Mask command ($87) 
clears these bits on the same basis. If interrupts are masked off, 

no interrupts can occur until they are enabled again. 


NON-VOLATILE MEMORY 


The 1K floppy disk controller shared memory RAM is backed up by the 
game power source that backs up the clock/calendar circuit. The last 
64 words in the 6505’s page 0 are’ reserved for the “parameter memory” 
of the~systen.—-Since the 6505 doesnot use these bytes, the 68000 can 
store data here which it wants to be able to access intact when the 
system is powered on. The reserved memory appears at the 68000 
locations $00C181 = SOOCLFF. 


THE BATTERY 


The disk controller also controls the charging current for the battery 
back up. Niw~Cd batteries last much longer if the charging current 

is pulsed with a 502 duty cycle at 200% of the normal charging current. 
While the disk controller is waiting for a command, it cycles the 
charging current at about ten times per second. The charging current 
is turned off while the controller is executing a command. 


As long as the system is plugged in, the backup battery is not in use. 
If there is a power failure, or the system is unplugged, the battery 
can last about 20 hours. 
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THE HARD DISK INTERFACE 


The hard disk interface is a general purpose eight bit parallel port 
which can be used to connect the Pippin hard disk controller to the 
Lisa. The Pippin is a 5-1/4 inch Winchester-type disk capable of 
storing about five megabytes of data. The 6522 which connects the 
interface to the 68000 bus also provides the programmable baud rate 
to the serial ports and generates the slow data bus that latches data 
for transfer to the contrast control latch. 


BARD DISK INTERFACE SIGNAL LINES 


DDO - DD? Disk Data lines. These eight bi-directional 
lines communicate data to and from the disk. 


RW Read/Write. RW controls the direction that 
data flows on the Disk Data lines. When RW 
is high, daca moves from the disk to the Lisa. 
When RW is low, data moves from the Lisa to 
the disk. 


This bit contains odd parity on the data being 
transmitted. If any parity errors are caught, 
the data can be retransmitted. 


Processor Strobe line. PSTRB controls the data 
flow from the Lisa to the disk interface. The 
timing diagram is given below. 


The Command line tells the disk controller that 
there is a command present. 


The Busy line is high when the disk controller 
is busy. BSY/ is also used as a handshake line 
with the C@/ signal. 


Open Cable Detect. If the disk controller is 
connected to the Lisa, the OCD line is low. 
If the controller is not connected, OCD is 
pulled high. 


Controller Reset. This line is driven by the CR/ 
bit (PB7) in the keyboard 6522. In addition, when 
the port is used as a general purpose parallel port, 
CRES/ is an input which can be read on the keyboard 
6522 PR/ bit if the CR/ bit is l. 


M3 1s an input that produces the M3 keycode. It 
provides a keyboard interrupt which the general 
purpose parallel port can use. 
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The 15 hard disk interface signal lines are controlled by a 6522. The 
relevant 6522 lines are: 


6522 line disk interface 


Peripheral A Port DDO - DD? Disk Data 
Control line | A PSTRB/ Processor Strobe 
Control line 2 A latch Cal 

Peripheral B Port DEN Disk Enable 
Peripheral B Port RW Read/Write 
Peripheral B Port CMD Command 
Peripheral B Port ocD Open Cable Detect 
Peripheral B Port PARITY/ Parity error 
Peripheral B Port BRC Baud Rate Control 


on the Keyboard 6522 CRES/ Controller Reset 
Control line 2 B BSY Busy 


The slow data bus. These eight bits are buffered with 

an LS245 to produce the eight Disk Data lines (DDO - DD7). 
They are also used to provide data to the contrast 
control latch. 


CAl generates the PSTRB/ signal. If CAl is in pulse 
handshake mode, and the DEN bit is low, the CAl line 
produces the proper pulse to transfer data to or from 

the disk with each read or write to the Peripheral A Port. 


CAl is fed directly to CA2 to allow latch mode to be 
used on the Peripheral A Port while data is being read 
from the disk. 


PRO - PB? 


an a ananealt SRenaEE SE eenmeenens menemeaens Renee i 
| BRC | RDP | OCD {| CMD | RW | DEN | I | 
_ a 2 nea oe ee Pee 


PB? PB6 PBS PBS PBI PB2 


PEO - PBl Unused. 


DEN Disk Enable. DEN enables the buffers which 
drive the disk interface lines. When DEN 
is low, the buffers are enabled. When DEN 
is high, they are disabled. 


RW controls the disk Read/Write line, and sets 
the data direction on the LS245 buffer for the 
Disk Data lines. When RW is high, the DD lines 
are enabled to read from the disk. When RW is 
low, the DD lines write to the disk. 
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cM The CM bit controls the CWD/ line to the disk. 
The CMD bit and the CMD/ line have the same level. 


ocD When the DEN bit is low, the OCD bit returns the 
state of the disk interface OCD line. 


RDP Read Parity permits a program to read the state of 
the PARITY/ flip-flop after completion of a data 
transfer. If RDP is high, there has been a parity 
error detected. 


Baud Rate Control. BRC is the output of the 
Tl timer that is connected to the Baud Rate 
Generator in the serial interface. It can 
be used to produce odd baud rates. 


CR/ is PB? on the other 6522 (the one on the 
keyboard). 


Unused. 


CB2 is connected to the disk interface BSY 
signal. : 
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Output/Input Register B gooDLOoT 3090! 

Output/Input Register A SOODLO9 ‘ 

Data Direceion Register B sOoDL11 y 

Data Direction Register A SO0D119 

Tl Low-order Latches/Counter $00D121 

Tl Righmorder Counter $00D1 29 

Tl Low-order Latches $00D1L31 

Tl High-order Latches $00D139 

T2 Low-order Latches/Counter SOODL41 

T2 High-order Counter $00D1 49 

Shift Register sOODLS1° 

Auxiliary Control Register $OODL59 

Peripheral Control Register $O0DL61 

Interrupt Flag Register $00D169 

Interrupt Enable Register $00D171 

Same as Register 1 but without : 

handshaking sool79 not 1 
y } 


6522 REGISTER ADDRESSES 


The register addresses for this 6522 jump by 4 words per register. 
This peculiar address decode allows a MOVEP.L instruction to transfer 
4 bytes to or from the Peripheral A Port during a disk read or write. 
By decreasing the number of instructions needed to transfer the data, 
the transfer rate is increased. 


The parity flip-flop should be reset before each transfer by clearing, 
then setting the PRES/ bit in the keyboard 6522. 
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THE HARD DISK CONNECTOR 
eee 
28% s3ir2s 


e 
13°12 1 «#10 


eee e@eeaee#e%eee# 
Bw 2 20 19 8 17 6 15 14 


Ground 
Ground 


blocked 

DD2 

Ground 

Ground 

DDS Ground 
DD6 CHK 
DD? 


1 
2 
3 
4 
5 
6 
7 
8 
9 
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1/0 SPACE ADDRESSES 


Address Function 


$000000-1 FFF Low Decode 
$002000-<3 FFF High Decode 
$004000-S5FFF Low Decode 
$006000-7FFF High Decode 
§008000—-9 FFF Low Decode 
$QQA000=BFFF High Decode 


$00C000~1 Disk Controller Command Byte 
$00C003-31 IOB 

s00cosl Interrupt Source 
$00C083 Interrupt Mask 
$00C181-LFF Parameter Memory “” 
$00CS01-7FF Shared Memory a 


§00D000 Interface CO Control Bit Reset 
$00D002 co Set 
$00D004 cl Reset 
§00D006 cl Set 
$oop00s C2 Reset 
sooDocdA c2 Set 
soopcoc c3 Reset 
SOODOOE c3 “Set 
$00D010 C4 Reset 
$00D012 C4 Set 
§00D014 cs Reset 
$00D016 cs Set 
$o00D018 cé6 Reset 
soopola. C6 Set 


$ocp041 7201 Channel 1 Register Data 
Control 

2 Data 
Control 


Hard Disk Interface 6522 ORB/IRB register 
ORA/ TRA 
DDRB 
DDRA 
TLC-=L 
T1C-H 
T1C-L 
T1C-8 
T2C-L 
T2C-8 
SR 
ACR 
PCR 
IFR 
IER 
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q 
soonf79 ORA/ IRA 


s00D181 _ Keyboard 6522 ORB/IRB register 
§00D183 ORA/ TRA 
$00D185 DDRB 
$00D187 DDRA 
$00D189 T1C-L 
SO0D1L8B TL C-#8 
s00D18D T1C-L 
SO0DL8F 

sooD191 

s00D193 

$00D195 

$00D197 

s$00D199 

SOOD19B 

g00D19D 

$00D19F 


§00E000 Memory Diagnostic DIAG] Reset 
$O0E002 Set 
SOQ0E004 DIAG2 Reset 
SOOE006 Set 


SO0E008 Context Selection SEGL Reset 
SOQOEOOA Set 
SOOE00C SEG2 Reset 
SOOEQOE Set 


$00E010 SETUP Register Set 

SOOEOL2 Reset 

$O0E014 Enable Soft Memory Error Detect Reset 
$OOEO1L6 Set 
SOOEOLS Enable Vertical Retrace Interrupt Reset 
SOOEO1LA Set 
SOOEOILC Enable Hard Memory Error Detect Reset 
SQOEOIE Set 
SOOE800 Video Address Latch 


$00F000 Memory Error Address Latch 


$00F800 Status Register 
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THE EXPANSION I/O SLOTS 


Three expansion devices can be connected to the Lisa system bus by 
inserting the expansion cards into the slots at the back of the 
machine. Slot 0 is the leftmost slot, as you face the back of the 
machine. The three expansion connectors are 56 pin ZIF connectors. 
These connectors permit you to install a card without removing the 
card cage from the chassis. 


SIGNAL DESCRIPTION 


‘The signal description given below describes the basic operation of 
the bus interface signals. Any signal that has the same name as a 
68000 signal (AS/ for example) is just a buffered version of that 
68000 signal, and its function on the expansion bus is the same as 
that described in the 68000 Micrprocessor User’s Manual. 


EXPANSION I/0 CONNECTOR (top view) 


Front of Machine 
 ememamanemommenmet a 
56 | 55 +5 Volts 
54 |] 53 Digital Ground 
52 | $1 Analog Ground 
So | 49 Lps/ 
48 | 47. AS/ 
46 | 45 +12 Volts 
44 | 43 
42 | 41 
40 
38 
36 


+5 Yolts | I 
Digital Ground | ! 
+5 STDBY | ! 
ups/ =| I 
READ | \ 
DTACK/ | l 
vPa/ | | 
BAL2 | | 
BALO | | 
Bas I 

BA6é | I 

BAS | 34 | 

BA2 | 32 | 

BDO 4} 30 | 

BD2 | 28 | 

| 26 | 
| 24 | 
{ 22 | 
1 20 | 
| 18 | 
| l 
I { 
I | 
{ | 
| | 
I I 
| I 
| | 


BD11 
BD13 
BDIS 
BG In 
E 
LDMA/ 
RESET/ 
INTn/ 
SLa/ 
-12 Volts -5 Volts 
$n 


Back of Machine 
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BDO - BDIS The 16 Buffered Data lines are the system data 
bus. These data lines are bidirectional and 
are pulled up on the motherboard. 


The 12 Buffered Address lines select one of 
2048 words in both the Low and High Selects. 
Each I/O card, therefore, has a maximum of 
4096 words (8192 bytes) of addressability. 
The Buffered Address lines are the 12 low 
address lines generated after the MMU. Thus, 
the operating system can assign a process a 
segment that encloses the 8192 addressable 
bytes on the 1/0 card, and the process will 
address the I/O card from addresses $0 to S1FFF 
independent of the location of the slot. 


Address Strobe indicates that the 68000 has 
initiated a memory cycle. Due to memory map 
delay, the high 3 address bits may not be 
valid when the address strobe is asserted, 
but the low 8 bits are valid. 


Upper Data Strobe indicates that the memory 
cycle being performed affects the upper data 
byte (BD8 = BDL5). 


Lower Data Strobe indicates that the memory 
cycle being performed affects the lower data 
byte (BDO - BD7). 


Data Transfer Acknowledge indicates that the 
I/O device has performed the data transfer 
requested by the 68000, and that the cycle 
can complete. j 


READ indicates the direction of the data transfer 
on the Buffered Data lines. When READ is high, 
data goes from the 1/0 device to the 68000. When 
READ is low, data goes from the 68000 to the device. 


Valid Peripheral Address indicates to the 68000 
that the addressed device works with a 6800 bus 
cycle. DTACK/ must not be asserted if VPA/ is 
asserted. 


Valid Memory Address indicates that the 68000 has 
received the VPA and is executing the requested 
6800 cycle. 


E is the 68000 equivalent of the 6800 phi2 clock. 
E is high for 4 clock cycles and low for 6 cycles. 
The frequency of the E clock is therefore 500 KHz. 
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BR Bus Request indicates to the 68000 that another - 
device wishes to take control of the bus. ; 


The 68000 issues a Bus Grant after the DMA device 
has been given control of the bus. If no higher 
priority device controls the tus and the present 
I/O card has asserted Bus Request, the card can 
take control of the bus when the Bus Grant signal 
is asserted. 


BG Out/ The Bus Grant signal is propogated to the lower 
priority devices when the current device is not 
using the bus. 


Bus Grant Acknowledge is produced by the 1/0 
device when it assumes control of the bus. It 
is asserted until that device is finished with 
the bus. : 


Load Direct Memory Access is used to load the 
DMA high address latch. Since the expansion 
slot has only 56 pins, the high 8 address lines 
cannot be sent to memory directly. Instead, 
a latch is provided on the CPU board to hold 
these 8 bits. The latch is loaded with the 
contents of the low 8 data bits (BDO - BD7) 
when there is. a rising edge on the LDMA/ 
signal. LDMA/ is pulled up on the CPU board. 
The DMA device must load this register each 
time it receives control of the bus, before 
any DMA cycles occur. 


The CPU Clock is the 5 MHz signal that drives the 
68000. It can be used as a general purpose clock, 
or to control timing during the DMA transfer. 


RESET/ tells the I/O device to return to its 
power-on state. RESET/ is asserted by the CPU 
when the power is turned on, and when the 
RESET instruction is executed. When the power 
is off, this line can be pulled low to turn 

it back on by using the soft-on feature. 


+5STDBY This signal provides a +5 volt power supply to 
those devices on the I/O board which need to be 
powered on whenever the system is turned on. 
The system clock/calendar circuitry is powered 
by this supply. When the normal +5 volt supply 
is operating, no current should be drawn from 
+5STDBY. The maximum current that can be drawn 
from this supply is 50 ma per expansion board. 
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INTa/ INTn/ is the Interrupt output from the expansion 
board to the 68000. When an expansion device 
interrupts the system, INTn/ should be held low 
until it is reset by the 68000. 


When the 68000 recognizes the INTn signal, it 
asserts the Interrupt Acknowledge signal. 

TARn/ is asserted when AS is asserted, so to 
provide a 68000 interrupt vector, the vector 

is applied to the bus and a DTACK/ signal is 
generated. If an autovector cycle is desired, 
the IAKn/ signal is routed to the VPA/ signal, 
and the 68000 provides the interrupt vector, 
depending on which slot the interrupt is provided 
for. To insure that a Bus Error does not occur, 
an I/O card should always provide an interrupt 
vector, even if it doesn’t think it asserted 

the interrupt line. To keep spurious interrupts 
from crashing the system, the interrupt handler 
should test each interrupt source on the I/0 
card, and should return from the interrupt 

if the card did not cause the interrupt. 


The two select signals for each expansion slot 
select contiguous 2048 word sections of memory. 
SLn/ selects the low 2048, and SHn/ selects the 
high 2048 words. The select lines are asserted 
after the the addresses are valid, and remain 
asserted until the data bus can be tri-stated 
on a read cycle. 


Power Supplies - 

The I/O cards are provided with four voltages 
from the power supply:.+12) +5, -5, and -12 volts. 
Both Digital and Analog Grounds are brought to 
the board. All three expansion_I/O cards can 
draw a maximum of 75 ma from the -5 volt line, 

and a maximum of 100 ma from the =I2 volt line. 
The cards can draw up to 10 watts from the other | 
lines. 


Zot mo 2 LY 


vse 345 50H wa @12V 
10 watts } 3 cards 
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DEVICE PROTOCOL 


To enable the boot ROM to boot the system at power on from an 
expansion device, every I/O card must conform'to certain 
identification and control protocols. Each card must contain a small 
ROM which identifies the card to the boot ROM. If the card has a 
boot program, the program also must be contained in this ROM. The 
I/O card’s ROM is addressed as the lowest significant byte of the SLn 
select for the card. The ROM contents are: 


I/O CARD TD AND BOOT ROM 


_—_—ooooOoOOOoO 
Address | type code | (bsnn nnon annn nonnn) 
1 I 
wen eee —t+ b=#bootable, s=™status, n=type 
| byte count 
| 
et 
boot program | 
data | 
I 


a | 


| checksum | 
et 


The type code is a 16 bit female byte sex number (most significant’ 
byte first) stored in the first two bytes of the ROM. If the first 
bit is al (see above), the device claims to be bootable. If the 
device’s status should be checked at boot time, its status bit (the 
second bit) is al. The other 14 bits are the identification mimber 
which identifies the card. ‘ 


Before the boot ROM executes the card’s boot program, it loads 
register Al with the address of the first word of SLa for the 
expansion slot. The boot program can therefore access the card by 
addressing relative to Al. 


If the status bit is on, the status program, which can contain device 
setup code, should begin at the first word of the program data. 

boot program, if present, should begin at the third word of the 

The status program should always return to the boot ROM leaving 
result in register DO. A result of 0 indicates that the device 
happy. The boot ROM checks each card’s status bit and executes 
status program, as required. It then checks parameter memory to 
decide which device to try to boot from, and checks that device’s 
boot bit to insure that a boot program is present. 
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The byte count is a 16 bit female byte sex number that ‘indicates the 
length in bytes of the boot program data. The boot program is stored - 
as bytes, but is read into main memory as 16 bit female words. The 2 
byte checksum should produce a0 (for all 16 bits) when it is added 

to all the rest of the data in ROM, including the type code and the 
byte count. : 


If the card returns a type code of $FFFF, the boot ROM responds as if 
there were no device in the slot. This code is provided for devices 
that do not contain a boot program during the hardware development 
phase. All production cards, however, must be self-identifying. 


Since addressing is done through the SLn decode, the expansion device 
boot ROM cannot be larger than 2048 bytes. Smaller ROMs can be used. 


DIRECT MEMORY ACCESS 


The DMA scheme provided by the Lisa is a slight modification of the 
system provided by the 68000 alone. Since che BG lines are daisy 
chained, the prioritization of DMA transfers is left up to the design 
of the expansion I/O cards and the location of the cards. The 
hardwired priority for DMA devices is: 


Highest Priority Slot 2 
Slot 1 
Lowest Priority Slot 0 


To insure that the daisy chain is not broken, any card that dees not 
use DMA should tie BG In to BG Out. The higher priority device 
should not propogate the BG signal to lower priority devices until it 
has finished using the bus. To insure proper propogacion of the 
daisy chained signal, ict is necessary to fill the expansion slots 
from right to left (from slot 2 to slot 0). Since a DMA device takes 
over the bus from the 68000, DMA transfers should be limited in time 
to about 1 as. 


The DMA controller associated with the expansion device controls the 
AS, UDS, LDS, and READ lines, as well as the data and address buses. 
The DMA controller should simulate the 68000 control of these lines 

as closely as possible. The timing on the DTACK/ signal is especially 
critical. To avoid wait states in the 68000 on normal memory fetches, 
the memory controller asserts DTACK/ one CPU clock cycle before the 
data transfer is complete. 


Page 58 
“LisaHWG81_058.PICT” 187 KB 1999-02-20 dpi: 72h x 72v pix: 2009h x 3026v 


@ Apple Lisa Computer Technical Information Page 0060 of 0083 


@ Apple Lisa Computer: Hardware Manual -- 1981 


Confidential Lisa Hardware Reference Manual 
GLOSSARY 


Asynchronous modem 
A modem which handles asynchronous transmissions. 
In asynchronous communication each character is 
transmitted with its own framing information telling 
the receiver where the character starts and stops. 
Since each character is a complete message, the time 
interval between successive characters need not be 
fixed. 


Autovector To handle certain interrupts, the 68000 automatically 
jumps to a location predefined for the given interrupt. 
The jump to the interrupt handler preloaded at this 
location is called an autovector. 


The rate at which a Mcdem sends and/or receives 
information. 110 baud means the Modem is handling 
approximately 110 bits per second. If there are 
two stop bits, a start bit, a parity bit, and a 
seven bit ASCII character code, 110 bits per second 
translates into about 10 characters per second. 


An acronym for binary digit. A bit 1s a piece of 
data with only two possible states, 1 or 0. 


4 contiguous set of bits. 


When a computer is turned on, it has to “bootstrap” 
itself into a useable state. The process of getting 
the operating system software into place and executing 
is called booting. 


A set of parallel wires (traces, paths) which carry 
related data and control information from one device 
to another. 


Byte A group of bits. On the Lisa, a byte is always 8 bits. 


Byte parity When bytes of data are being moved around, one or more 
bits in the byte can get improperly flipped. These 
incorrect bits can sometimes be detected by checking 
the byte parity. The byte’s parity is odd if there is 
an odd number of 1 bits in the byte. If another bit is 
available in the byte, the sender can insure that every 
byte has even parity upon being transmitted. The receiver 
can then check each byte’s parity, and if any are odd, 
it can inform the system that something has gone wrong. | 


The metal box in which the printed circuit cards reside. 
Similar to byte parity. A number used to ensure that 


data has not suffered degradation during transfer. 
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A continuous, regular waveform used to control the 
timing of logic decisions. 


Complementary Metal Oxide Semiconductor. CMOS combines 
N-channel and P-channel MOS transistors to give rather 
high speed operation, good noise rejection, low power 
consumption, and large fanmout. Since the non-volatile 
parameter memory must not consume much power, it is 
implemented with CMOS chips. 


Control Oriented Processor System 
cru : Central Processing Unit. A Motorola 68000 in the Lisa. 


cvsD Continuously Variable Slope Delta Modulator. A kind of 
analog to digital and digital to analog converter. 


Cycle The interval between two clock pulses. 


Daisy chain A daisy chain is a method of connecting several devices 
to a single I/O port. 


Decode The opposite of a select. The decoder’s input address 
determines which of its many outputs will go low. 


DMA Direct Memory Accéss. Normal memory access goes through 
the 68000 and its memory manager. A device can, however, 
read and write memory locations directly, without any 
intervention from the CPU. 


Disk Operating System 3.3, used on the Apple II. The 
floppy disk controller used by the Lisa is very similar 
to that supported by DOS. 


Digital to Analog. When a digital signal is used to 
control an analog device, the bits in the digital word 
must be converted into analog voltage levels. 
Ecc Error Correction Code. 
a ‘ Event, A block of data associated with an exception. 
Cerne byte Sac ig MELO LSE acdar in See 2) RAR a2 3: 
A FIFO First In First Out, A queue. . 


Flip flop A digital circuit used to store one bit of data. 


Femace: By tes stored in MSA T LSB adder jn seg hentia] RAM 
byte order (a(/« FoFe) | 
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Gate A gate is a switch which controls the flow of data 
according to some Boolean function of its inputs. 
An AND gate, for instance, has two inputs, a data 
line and a control line. If the control line is 
0 (false), data from the input line cannot get to 
the output (anything AND false is false). If the 
control line is 1 (true), any data on the data line 
is allowed to pass through the gate. 


Handshaking controls the transfer of data between 
devices. Each device has a way to tell the other 
that its side of the operation is complete. For 
example, a processor writes data to a register, 
then sends a signal to a device that data is ready 
to be read. The device reads the data, then sends 
the processor a signal that it has finished reading 
and is ready for more. The handshaking insures 
that the processor does not write new data to the 
register (clobbering the old data) before the 
device has had a chance to read the old data. 


A computer hangs when it gets into some infinite 
loop or wait state. There are times when the only 
recourse is to reboot the machine. 


A disk that is not floppy. Hard disks look a little 
like a stack of phonorecotds. Higher data densities 
can be supported by a hard disk because it does not 

change size and position as much as the floppy disk 

does. 


A voltage state. A high voltage can signify either 
true or false, depending on the logic being used. 


Kile-Hertz (1000 cycles per second) 


Input/Output Block. A block of memory used to control 
and communicate with the floppy disk controller. 


Light Emitting Diode. A semiconductor device that emits 
light when a small current passes through it. 


A voltage state (0 volts). Low voltage can signify either 
true or false, depending on the logic being used. 


ma milliamp 


: Mainframe ,, The main computer. 
ae eer a, he (atx Lot te: =a ey ae ails: a 


ne ees Pe 
t pig Sep eR ea? 6 fe 4 SOE Cj 
Megahertz a / a 


Bare Lim MSbyte ‘ LShyte of a ee when Accessing 
seguential byt (ala 9060) - 
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Modulator/Demodulator. To send digital data over a 
telephone line, the Modem transforms the bit patterns’ 
into a stream of modulations of a carrier signal. At 
the receiving end, the signal is demodulated to recover 
the data. , 


Memory Management Unit 
millisecond. 


Nearly all keyboard interfaces work by scanning the keys 
and forming a two dimensional matrix representation of the 
state of the keys. The logic involved can tell when two 
keys are being pressed simultaneously (rollover), but 

when three or more keys are held down, phantom keys 

can appear (there are hidden paths through the logic array). 
Nekey rollover design adds a diode in series with every 

key switch to eliminate the hidden paths. 


A set of bits smaller than a byte. On the Lisa, 
a nibble is 4 bics. 


Non-Maskable Interrupt. When the processor receives 
an interrupt, it usually checks a mask to see whether 
it should pass control to that interrupt’s handler. 

A non~maskable interrupt is always honored. 


manosecond. A billionth of a second. Also abbreviated 
as nsec. 


512 bytes 


Parameter memory 


A non~volatile block of RAM set aside for such things 
as the system serial number, configuration data, and 
user-defined information. 


Parity has to do with the number of one bits in a word. 
If there are an even number, the word has even parity. 
Parity can be checked to insure that one bit in a word 
has not been incorrectly flipped during transmission. 


Program Counter 
Peripheral Interface Adapter (6522 on the Lisa) 
A sealed 5 megabyte hard disk made by Apple 


An I/O location. 
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Privilege violation 
The 68000 has two states of privilege, User and Supervisor. 
Certain instructions (RESET, for example) can occur only 
in supervisor state. An attempt to execute 4 priviliged 
instruction from user state causes a privilege violation 
interrupt to be generated. 


Programmable Read Only Memory 


Random Access Memory (actually ROM is also random access 
memory--RAM, however, is read/write memory). 


Read Only Memory. 

A communication protocol. 

Read/Write/Track/Sector. The controlling routines that 
drive the floppy disk controller both on the Lisa and the 
Apple II. 


Segment A segment is an independent address space. Ie may have 
little obvious relation to physical memory. 


Shift register A register is a device which can store information. A 
shift register is able to shift all its bits left or 
right. 


SSP . Supervisor Stack Pointer. See Privilege Violation. 


Synchronous modem’ 

Synchronous transmission puts the framing information 
around a group of characters. The transmitter then 
automatically inserts fill characters into the stream 
whenever necessary to maintain synchronicity. Because 
more of the bits are data (there are fewer stop and 
start bits than in asynchronous transmission), data 
transfers can go at a faster rate. 


tristate A logic output that can be inactive, high or low. The 
three states are, therefore, active high, active low, 
and open. 


micro-second. The letter “u’ is used because it looks 
like the small Greek letter m (small Roman ‘m’ is used 
for milli, and large Roman ‘M’ is used for Mega). 


A group of bytes. On the Lisa, a word is usually 16 
bits, or two bytes. Long Words are 32 bits or four 
bytes. 


Zero Insertion Force 
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